الحمد لله رب العالمين» القائل في محكم التنزيل ( وعلمك مالم تكن تعلم » وكان فضل الله عليك 
عظيما ) » والصلاة و السلام على سيدنا محمد سيد العلماء و سيد الأولين و الآخرين رسول رب 
( سبحانك لا علم لنا إلا ما علمتنا إنك أنت العليم الحكيم ) 
هذا الكتاب موجه إلى كل من مبتدئ في البرمجة وإلى طلابنا في المعاهد و الجامعات لتكون 
ع رکا لچک اشا( 
وأدعو الله أن يتقبله خالصاً لوجه وأن يكتبه في صحيفتي و صحيفة من سيتابع في نشره 
وأن يجعله عملا ينتفع به إلى يوم الدين 
فمن وجد خطا فهو مني وما کان فيه من صواب فمن توفيق الله 
وأخر دعوانا الحمد لله رب العالمين 
أخوكم في الله 


mh2n@scs-net.org 
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المحتويات 


۲ 
كيفية كتابة برنامج بلغة ++© ۲ 
الإعلام عن المتغيراتا 00000 ل 
أنواع المثغيرات ٤‏ 
1 
أولويات العمليات الحسابية 1 
الأدوات المنطقية ل 
۹٩‏ 
الجملة الشرطية موءام إا ۹ 


حلقة الإيقاف )هعاb‏ 
حلقة الاستمرار ما00 ا 
تعليمة الانتقال 0أم ر 
سلسلة فييوناشي esأمھ؟ F00‏ 1 ۲ 
المصفوفاتءرهA۲۲‏ ۳۲ 
۳ 
المصفوفات ثنائية البعد ۳۸ 
30 
کر سیل اکل سل اتر ٤‏ 
° 
الملفات وه||؟ ٤۹‏ 
oY‏ 
القراءة والكتابة على ملف ببرنامج واحد oo‏ 


۱ 
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تسمية المتغيرات في لغة ج++٥°‏ 


-١‏ يجب ك لا تکون اسما المتغيرات من 
الكلمات nllحجرjة‏ ) (RESTRAINED WORDS‏ 
أو الكلمات التي تحمل معنا خاصا مثل أج" 
1- يمكن أن يحتوي الاسم على آي حرف من الحروف الأبجدية صغيرة أو كبيرة وعلى أي رقم 
من الارقام كذلك يمكن أن تحوي الإشارة( ) 


۳- لا يجوز أن بيدأ الاسم برقم 


متال: 
7-up‏ 
Salim!‏ 
No#‏ 
Ag‏ 
a-a‏ 


-إن هذه اللغة ساس لسالة الدرفى أي الحرف الصغير ليس هو الخرفى الكبير 
کا امول ود فهر ير المتحول ۸ 


كيفية كتابة برنامج بلغة ٥++‏ 


لكتابة برنامج يجب أن نستهل البرنامج بالمكتبات التي تدعم التعليمات الواجب استخدامها و 
المكتبة التي سنستخدمها الآن هي مكتبة "0564| 
يحيث تمكننا هذه المكتبة من استخدام الأوامر التالية 


CİN>> 
COUÎ<< 
endl 


٥©++ لغه‎ 


خطأ بسبب البداية برقم 
E‏ 
خطأً بسبب استخدام ( # ) المحجوزة 
عبارة صحيحة 

خطأ بسبب إشارة الطرح 


إدخال وتقراً 0 € 

إخراج و تقرا c out‏ 

end line نهاية سطر وتقراً‎ 
١ 
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تتعامل هذه لغة ++© مع عدد كبير من المكتبات وكل مكتبة لها اكواد خاصة بها و يمكن التعامل 
مع عدة مكتبات في آن واحد وسنتحدث عن كل مكتبة عندما بتطلب البرنامج ذلك 

كيفية كتابة البرنامج 

يكتب أي برنامج كما في الشكل التالي: 


مقدمة لذكر اسم llئnكتبة #include <iostream.h>‏ 

مقدمة أيضا سنشرح هذه الأوامر في الفصول اللاحقة ) Void main(‏ 
قوس الدلالة لبداية البرنامج 

نبدأ بالإعلام عن المتغيرات 

يكتب هنا البرنامج 

قوس الدلالة على نهاية البرنامج 1 


الإعلام عن المتغيرات 
ليتمكن المستخدم من استخدام المتغيرات التي يريدها يتطلب البرنامج الإعلام المسبق عن أسماء 
هذه المتغيرات فمثلاً للتعامل مع متغيرين من نوع ( عدد صحيح ) نكتب ما يلي: 
int a;‏ 
int b;‏ 
ويمكن أن تكتب بالشكل التالي ; ط,ھ أ١ا‏ 


وسنستخدم البرنامج 0ظ۲ ں٣‏ لتنفيذ الأمثله كما هو ظاهر في الشكل : 


۳ 
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& Turbo C++ 


ويكفيك أن تضغط القائمة أ۴ وتختار الأمر «ه وتبدأً بكتابة البرنامج وتضغط الأمر 

Run 

لكي تنفذ البرنامج 

مثال: 

اكتب برنامج يقوم بالتصريح عن متحولين صحيحين ومن ثم يقوم بجمع قيمة الأول إلى عشرة 

وإسناده إلى قيمة المتحول الثاني ومن ثم يقوم البرنامج بطباعة قيمة الناتج ؟ 

#include <iostream.h> 
void main ( ) 


int vor1; 

int vor2; 

cin>> var1; 

var2 = varî + 10; 

cout<< " varl+ 10 is "<<var2; 


} 


العبارة ;۷2۲1 << ١أ ٠‏ تعني أدخل قيمة المتحول ۷2۲1 


المتغيرات الحرفية ماع 
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تتضمن. الحرو ف بكافة أشكالها ى-الرموز و الفراغات ( مساقة ار غة )مل ٠“‏ 
و لصم و و مور و ر 


char a,b; 
a 
b=''; 
char var1; 
Vala 7 
integer المتغيرات الصحيحة‎ 
٠۲۷٠۷ تتضمن قيم عددية صحيحة يمكن أن تأخذ قيمة تصل إلى‎ 
: وتكتب على الشكل التالي‎ 
int a; 
a= 100; 
floating المتغيرات العددية العشرية أ0م‎ 
تتضمن جميع الأعداد الحقيقية‎ 
وتكتب على الشكل التالي:‎ 
float xX; 
KE DZ 
كهuاbام المتغيرات العددية العشرية الطويلة‎ 
هي نفس المتغيرات العددية العشرية ولكن يمكن تمثيلها إلى خمسة عشر خانة‎ 
وتكتب على الشكل التالي:‎ 
double x; 


مثال : 
أوجد نتيجة التمرين التالي 
#include <iostream.h>‏ 
void main ( )‏ 


MM Us 


o 
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float X,y,Z; 

1 2 

2 کل 

y = (float ) (5/2); 

j = ( float) 5/2; 

2 A 

cout<<i <<endl<< x<<endl << y<<endl << j<<endl << z<<endl; 


1 


الاب 
x= 2.000 y= 2.000 j-5‏ 2| 


العمليات الحسابية و الأدوات المستخدمة فيها 


للجمع تستخدم + 
للطر ج 
باقي القسمة % 
للضرب 


للزيادة بمقدار واحد. ++ 
اا و 


أولويات العمليات الحسابية 
-١‏ الزيادة و النقصان عندما تأتى قبل العدد 
۲- الأقواس ٤‏ 
۴- إشارة السالب 
-٤‏ القسمة و باقي القسمة و الضرب 
اج و افرح 
-٦‏ المساواة 
۷- الزيادة و النقصان المتأخرة بعد العدد 
ملاحظة 
في حال وجود عمليتين لهما نفس الأولوية نبدأ بتنفيذ العملية الأقرب إلى اليسار. 


٦ 


PDF created with pdfFactory Pro trial version www.pdffactory.com 


الأدوات العلاقية : 


الأكبر < 
الأاصغر > 
أكبر أو يساوي => 
يساوي کح 
ان کان يساوي کے 
إن کان لا 

يساوي =!إ 


مثال: 
أكتب برنامج لإدخال عدد ما ومن ثم طباعة جدول ضرب له 
الحل: 
#include < iostream.h>‏ 
void main ( )‏ 
1 
Int xX;‏ 
CİN>> X;‏ 
coui<< xX <<endl;‏ 
coui<< xX *2<<endl;‏ 
coui<< xX *3<<endl;‏ 
coui<< X *4<<endl;‏ 
coui<< X *5<<endl;‏ 
coui<< X *6<<endl;‏ 
coui<< X */7<<endl;‏ 
coui<< xX *8<<endl;‏ 
coui<< x *9<<endl;‏ 


{ 
مثال آخر: 
اكتب برنامج لإدخال تلاثة علامات لطالب ومن ثم طباعة معدل هذه العلامات 


۷ 


PDF created with pdfFactory Pro trial version www.pdffactory.com 


#include <iostream.h> 
void main () 


int a,b,c; 
Cin>> a >> bD >>c ; 
cout<<"the averaje is"<< ( a+b+c )/3; 


الأدوات المنطقية 
and‏ && 
Or‏ | 
not‏ 1 
مثال: 
Int a=b=3;‏ 
A <3 false‏ 
A<=3 true‏ 
A>b false‏ 
A!=b false‏ 
A= = true‏ 


م 


الأدوات الدقيقة : 

تتميز لغو ++© أنها تستخدم أدوات دقيقة تتعامل مع أط وتستعمل هذه الأدوات مع المعطيات 
c٣‏ , ہا ولا تستخدم مع غیرها. 

وهذه الادوات هي: 


الشرح التعليمة 
~ı Not‏ 
إزاحة الى اليسار < 
إزاحة الى اليمين << 
Xor‏ ۸ 
And‏ & 
Or‏ 


۸ 


PDF created with pdfFactory Pro trial version www.pdffactory.com 


وتكون الأولوية حسب ترتيب الجدول. 


مثال: 
إا كان-لدينا × ممثل۔بالنظام الثنائي 


N OS ES KS CH DOS EBED 


المطلوب أوجد قيمة نفي × أي ×ہ 


الجواب: 
TIT AON TIO. 1‏ 


الادوات الشرطيهة: 
وهي عبارة عن حلقات تتم ضمن شروط يحددها كاتب البرنامج 


الأدوات الشرطية الأولية conditional operator‏ 


الشكل النموذجي هو ٠‏ 


مثال : 
اكتب برنامج لحساب القيمة المطلقة للمتحول ل باستخدام المعامل الشرطي ( الأداة الشرطية ) 
و المعرفة بالعلاقة التالية 
¥ تساوي × بالقيمة المطلقة 
أي أن × = ل عندما 0<× 
و ×- =لعندما 0 X>‏ 
الحل: 
#include < iostream.h>‏ 
void main ( )‏ 


1 


۹٩ 
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int y, X; 

CİiN>> xX; 

VJ SX >= 0) xX xX 
cOUi<< JY; 


{ 


الجملة الشرطية موام - إا 


مثال آخر 

اكتب برنامج لإدخال طولك و طول زميلك بشرط 

إن كان طولك أكبر من طول زميلك عندئذ قم بطباعة طولك ومن ثم قم بحساب معدل الأطوال 
ثم أطبعه وإلا فأطبع طول زميلك وأطبع ضعف طوله وأطبع نصف طوله 


الحل: 
#include <iostream.h>‏ 
void main()‏ 


int zy; 

cout<< "Inter your long"<<endl; 
CMS Z2 

cout<< "Inter friend's long"<<endl; 
cin>> y; 

COU esemssess sese <<endl; 
if])z<y( 


cout<< "You longer"<<endl; 
cout<< "Your long is "<<z<<endl; 
cout<<endl; 

cout<< " The average longs are "; 


1۰ 
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cout<< (Z+¥y)/2; 


} 


else 


{ 


coui<<" Your friend is longer"<<endl; 
cout<<" He's long is "<<y<<endl; 
coui<<" J*2 = "<<y*2<<endl; 

SOUS VA — VA 

ا 
} 


مثال آخر: 
ناقش حالة إدخال عددين بمختلف الحالات 


#include <iostream.h> 
void main() 


MZ YE 

cout<< "enter first number"<<endl; 
CiNn>> Z; 

cout<<"enter scanned number"<<endl; 
cin>>y; 

İf1)z<y( 

cout<<"the large number is first"<<Zz<<endl; 
else 

if])z==y( 

cOUi<<"Z=Yy"; 

else 

cout<<"the large number is scaned"; 


1 


(switch — case) ق‎ 
شکلها العام‎ 
switch(Expression) 


١ 
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{ 


case constant 1 : statement 1; 
break; 

case constant 2 : statement 2; 
break; 


case constant x : statemenît X; 
break; 

default : statement; 
break; 


e 
يجب أن يكون 10۸ءئومإم×ع المعرف في ۸ءاأس۷ء قيمة صحيحة‎ 


مثال: 

#include <iostream.h> 
void main() 
Int X; 
Cin>> xX; 
switch (xX) 
{ 
case 1: 
cout<<" welcome"<<endl; 
break; 
case 2: 
cout<<" hello student"<<endl; 
break; 
case 3: 
cout<<" introdaction to c++"<<endl; 
break; 
default: 
cout<< "bye bye"; 
1 

مثال اخر: 


1 
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اكتب برنامج يطبع اسم الكوكب في المجموعة الشمسية مرتبا من الأقرب إلى الشمس بحيث 
ندخل إلى البرنامج رقم الكوكب فيطبع البرنامج اسم الكوكب 
الحل 
#include <iostream.h>‏ 
void main()‏ 
int x;‏ 
cout<< " inter number a planet "<< endl;‏ 
CİN>> X;‏ 
switch (xX)‏ 
{ 
case 1:‏ 
cout<<" its a Mercury"<<endl;‏ 
break;‏ 
case 2:‏ 
coui<<" its a Venus"<<endl;‏ 
break;‏ 
case 3:‏ 
cout<<" its a earth"<<endl;‏ 
break;‏ 
case 4:‏ 
coui<<" its a Mars"<<endl;‏ 
break;‏ 
case 5:‏ 
cout<<" its a Jupiter"<<endl;‏ 
break;‏ 
case 6:‏ 
cout<<" its a Saturn"<<endl;‏ 
break;‏ 
case 7:‏ 
cout<<" its a URANUS"<<endl;‏ 
break;‏ 
case 8:‏ 
cout<<" its a NEPTUNE"<<endl;‏ 
break;‏ 
case 9:‏ 
cout<<" its a PLUTO"<<endl;‏ 
break;‏ 
case 10:‏ 
cout<<" its a senda "<<endl;‏ 
break;‏ 
08 
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default: 
cout<< "err no plant to resemble this number"<<endl; 


break; 
1 
1 
مثال آخر:‎ 
اكتب برنامج يحول من الأرقام العربية الأصل إلى الأرقام الموافقة لها بالرومانية‎ 
الحل:‎ 
#include<iostream.h> 
main() 
int x; 
cout<<"enter the decimal number:"; 
CİN>> X; 
while(x<=12) 
{switch(x) 
{ 
case 1: 
{cout<<"l"<<endl; 
cout<<"enter the decimal number:";} 
break; 
case 2: 


{cout<<"ll"<<endl; 

cout<<"enter the decimal number:";} 
break; 

case 3: 

{cout<<"llI"<<endl; 

cout<<"enter the decimal number:";} 
break; 

case 4: 

{cout<<"IV"<<endl; 

cout <<"enter the decimal number:";} 
break; 

case 5: 

{cout<<"V"<<endl; 

cout<<"enter the decimal number:";} 
break; 

case 6: 

{cout<<"VI"<<endl; 

cout<<"enter the decimal number:";} 


٤ 
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break; 

case 7: 

{cout<<"VlII"<<endl; 

cout<<"enter the decimal number:";} 
break; 

case 8: 

{cout<<"VIlI"<<endl; 

cout<<"enter the decimal number";} 
break; 

case 9: 

{cout<<"IX"<<endl; 

cout<<"enter the decimal number";} 
break; 

case 10: 

{cout<<"XlI"<<endl; 

cout<<"enter the decimal number";} 
break; 

case 11: 

{cout<<"XlIl"<<endl; 

cout<<"enter the decimal number";} 
break; 

case 12: 

{cout<<"XIlI"<<endl; 

cout<<"enter the decimal number:";} 
break; 

default: 

cout<<"NOOOO":; 

break; 

1 . 
CİIN>>X; 
} 
ُ 


1° 
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حلقَةَ 0۲ 
كلها العا 


الشرح : عبارة عن شرط يقيد حركة ]0١‏ وغالبا ما يحوي قيمة نهائية 
وهذا الشرط يك هه الاي ةرلابتدائية و القيمة البهاة مخسة رة المتحول ؛ 


مثال: 
اكتب برنامج يطبع هذه الإشارة * عشر مرات متتالية 


#include<iostream.h> 
main() 
{ 
int i; 
Or{(iST IES IO TEE) 
coui<< "*"; 
1 
مثال آخر:‎ 
. )٠١( إلى الرقم‎ )١( اكتب برنامج يقوم بطباعة الأعداد الفردية من الرقم‎ 
الحل:‎ 


٦ 
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#include <iostream.h> 
void main() 

١ 

Int Xx; 

ÎOrK=1; X<=15 ; X=X+2) 
cout<<x<<endl; 


1 


ملاحظة : 
عند مقدار الزيادة واحد واحد نكتب_ (++ا) أما عند الزيادة اثنان اثنان نكتب (2+ادا) 
وبإمكاننا أن نعرف المتحول داخل الحلقة أيضا مثل (2+ 1=¡ ; for(int i=1; i=15‏ 


مثال آخر: 
اکتب برنامج يطبع الارقام 10 <.....2.3 بشکل عامودي 
الحل : 


#include <iostream.h> 
void main() 


for(int x=2; x<=10 ; xX++) 
coui<<x<<endl; 


1 


حلقات ١إم]؟‏ المتداخلة 

يمكن أن تأتي حلقة ٣‏ تابعة لحلقة ۲ أخرى أي متضمنة بداخلها على الشكل التالي 
For (l=1;l<=10;| ++)‏ 
For (j=2;j<= 20; j ++)‏ 


وهنا تنفذ العملية الثانية حسب الحلقة الأولى 
أي كل مرة تنفذ فيها الحلقة الأولى تنفذ الحلقة الثانية من البداية إلى النهاية 


: مثال‎ 
اكتب نتيجة البرنامج التالي‎ 
#include <iostream.h> 
void main() 
E 
Int J ,l; 
for(i=1; i<=3 ; i++) 
for(j=1; j<=4 ; j++) 


1۷ 
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{ 
coui<<i;‏ 
couit<<j;‏ 
ا 
ُ 
الجواب : 
4 21222324 11121314 
حلقَ While‏ 
شكلها العام 
while(condition)‏ 
Statement ;‏ 
ملاحظة ٠‏ 
يجب إضافة تعليمة في نهاية هذه الحلقة لتسمح العودة إلى بداية البرنامج حتى يتم فحص الشرط 
مرة أخرى 
مثال: 


اكتب برنامج يقوم المستخدم بإدخال عدد ما ومن ثم يفحص البرنامج هذا العدد لمعرفة فيما إذا 
كان هذا العدد أولي أم لا 


الحل: 
#include <iostream.h>‏ 
void main()‏ 


int x,İ; 
CİN>> X; 
i=2; 

while (x>i) 


if (x%iİ==0) 


cout<<"the number in not prime";// make i right any thing 


۱۸ 
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i=X+1; 


1 


else 
if(x % i !=0) 
i++; 


} 
== 
cout<<"the number is prime"; 


1 


مثال آخر: 
اكه رتام باون اة اكل فة ما 
وطالما كانت هذه القيمة موجبة فيطبع البرنامج هذه الإشارة * على سطر جديد . 


الحل 
#include <iostream.h>‏ 
void main()‏ 


int x,i; 
Cin>> xX; 
while (x>0) 
{ 
COUi<< 
CİIN>>X; 
} 
1 


Mk 


<<endl; 


وهنا يبقى البرنامج في الحلقة ولا يخرج منها إلا بكتابة قيمة سالبة 
أما إن اردنا أن يخرج البرنامج بعد أول مرة فنكتب هذه العبارة 
X=X-X;‏ 

بدلا من العبارة 

Cin>>x; 


۹ 
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do while حلقَ‎ 


الشكل العام 


الشرح: 
ابق ضمن الحلقة 0ل حتى يتم تنفيذ الشرط while (conditi0¬)‏ 


مثال 
اكتب برنامج يقوم بجمع الأعداد المدخلة ومن ثم يتوقف عن العمل ويقوم بطباعتها بمجرد إدخال 
الرقم صفر. 


#include <iostream.h> 
void main() 


int x, sum; 
sum = 0; 
do 

(1 
CİIN>>X; 

SUM+=X; 

}jwhile (x!=0); 

cout<<"sum of number is ="<<sum; 


1 


ملاحظة أخرى 
يمكن كتابة هذا البرنامج بالحلقة ١أ‏ فقط على النحو التالي 


۰ 
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#include <iostream.h> 
void main() 


int x, sum; 
sum = 0; 
do 
CİIN>>X; 
While ( x!=0) 
{ 
SUM+=x; 
Cin>>x; 


1 


حلقة الإيقاف )جءإb‏ 
وظيفتها : إيقاف بنية أو حلقة تكرار عند تحقق شرط أو شروط معينة . 
عند تنفيذ هذه اأتعاب لتعليمة يتم القفز إلى سلسلة الجمل التالية للبنية أو حلقة التكرار. 
مثال: 
#include <iostream.h>‏ 
void main()‏ 


for(int i=1 ; i<= 100 ; i++ ) 
{ 
coui<<i; 
= = 10( 
break; 

ا 
1 


حلقة الاستمرار ںہ conti‏ 
تعمل هذه الحلقة على تجاوز تنفيذ بقية التعليمات فى التكرار خلال الدورة الحالية و الانتقال إلى 
الدورة التاة. ۰ 
مثال: 
#include <iostream.h>‏ 
void main()‏ 


{ 


۲١ 
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for(int i=1; i<=100; i++) 


{ 

if(i==10) 
continue; 
couit<< İi <<endl; 


1 
1 


مال آخر: 
حر: 
اكتب برنامج يقوم بطباعة جميع الأرقام الواقعة بين )١(‏ إلى )٠٠١(‏ التي تقبل القسمة على 
#include <iostream.h>‏ 
void main()‏ 


for(int i=1; i<=100; i++) 


{ 
if(i%6=0 && i%4=0 && i%2=0) 
cout<< i<<endl;}} 


طريقة أخرى أسهل: 
#include <iostream.h>‏ 
void main()‏ 


for(int i=1; i<=100; i++) 


if((%2!=0 ) 
continue; 
else if(i%4!=0 ) 
continue; 
else if(i%6!=0 ) 
continue; 
cout<<i<<endl; 


1 
1 


تعليمة الانتقال داهن 

تفيد هذه العملية في الانتقال من سطر برمجي إلى آخر مع تجاوز لبعض الأسطر البرمجية من 
أجل تنفيذ أمر معين. 

مثال: 

اكتب برنامج يقوم بإدخال رقم ما فإن كان الرقم أصغر من عشرة فيطبع البرنامج العبارة التالية 
The number is less ten‏ 

أما إن كان الرقم أكبر أو يساوي العشرة فيطبع البرنامج العبارة 


۲ 
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The number is equal or beggar ten 


#include <iostream.h> 
void main() 

Int X; 

CİN>>X; 

if(x<10) 

goto one; 

else goto two; 

one: cout<<"the number is less ten"; 

two: cout<<"the number is equal or beggar ten";} 


ولكن نجد أن البرنامج يماي الياركين معا إن كان الرقم المدكلة احق من عشرة 
وهذا الخطأً سببة: 
البرنامج يقوم بتنفيذ التعليمات سطر سطر ويما أن العبارة الثاني جاءتا تماما بعد العبارة الأولى 


تدریبات: 

اکتب برنامج يقوم المستخدم به بإدخال عدة أعداد / " / ويقوم بجمعها بحيث يحدد المستخدم 
عدد الأعداد /۸/ قبل إدخالها ؟ 

اختر الطريقة المناسبة لحل هذا المتال؟ 


الحل الطريقة الأولى باستخدام الحلقة عااإسw do‏ 


#include <iostream.h> 
void main() 


int Nn,x,sSUmM; 
sum=0; 
cin>>n; 

do 

{ 
CİIN>>X; 
SUM+=X; 
E 


while(n!=0); 
cout<<"the sum of number is "<<sum; 
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الطريقة الثانية باستخدام الحلقة عاأاس 


#include <iostream.h> 
void main() 

int n,count=1,nUmM,SUM=O0; 
cout<<"enter n"; 

cin>>n; 

while(count<=n) 
cin>>num; 
sSum+=num; 
COUNÎ++; 


cout <<"the sum of number is"<<sum; 


1 


الطريقة التالثة باستخدام الحلقة |0٣‏ 


#include <iostream.h> 
void main() 

{ 

int sum=0,x,i,n; 
cout<<"enter n"<<endl; 
cin>>n; 

for(i=1; i<=n ; i++) 


couit<<"enter namber"<<endl; 
CİIN>>X; 
SUM=SUM+X; 


cout<<" the sum of number is = "; 
cout<<sum<<endl; 


1 


اكتب برنامج يمثل آلة حاسبة بسيطة تدخل عددين فقط بحيث نختار عملية من العمليات الحسابية 
الأربعة مثل أن نكتب ۲+١‏ فيعطينا البرنامج الجواب 
وناقش حالة القسمة على صفر؟ 
#include<iostream.h>‏ 
void main()‏ 


int x,y; 
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char r; 
Cİin>> X; 
Ccin>> r; 
cin>> y; 
switch(r) 
{ 
case '+': 
COUİi<<X+Yy; 
break; 
case '-': 
COUi<<X-Y¥; 
break; 
case '"*': 
cout<<X*Yy; 
break; 
case '/': 
iİ])/==0( 
couit<<"error"; 
else 
coui<<X/y; 
break; 
default: cout<<" chose the right operate";}} 


مثال مماثل ولكن بتطوير أكثر 
اكتب نفس البرنامج السابق ولكن اسمح للبرنامج بأن يدخل العمليات أكثر من مرة 


#include<iostream.h> 

void main() 

int x,y,n,count; 

char r; 
cout<<" enter how many play program"<<endl; 
cin>> n; 
Cin>> xX; 
Cin>> r; 
Ccin>> Yy; 

while(n!=0) 

{ 

switch(r) 

{ 
case '+': 


Yo 
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cout<<"the score is = "<<x+y<<endl; 
2 eR 
1 
break; 
case '-': 
cout<<"the score is = "<<x-y<<endl; 
COUİÎ< <" ---------==-=-=-===-=---- "<<endl; 
1 
break; 
case "": 
cout<<"the score is = "<<x*y<<endl; 
COUİÎ< <" ---------==-=====-=---- "<<endl; 
1 
break; 
case '/': 
cout<<"the score is ="; 
i1)/==0( 
cout<<"error"<<endl; 
else 
cout<<x/y<<endl; 
COUİÎ< <" ---------==-=====-=---- "<<endl; 
1 
break; 
default: 
cout<<" chose the right operate"<<endl; 
COUİÎ< <" -----------====-==-==--- "<<endl; 
ا‎ 
1 . 
CİIN>> X; 
Cin>> r; 
Ccin>> Yy; 
1 
ُ 
متال:‎ 
اكتب برنامج يقوم بطباعة الشكل التالي‎ 
4 
12 
123 
1 
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1234 
1-23-45 
الحل: 
باستخدام علاقة رياضية أي يكون الخرج رقما وليس شكل هو كالآتي: 
#include<iostream.h>‏ 
void main()‏ 
Int xX;‏ 
0 
for(int i=1;i<=5 ;ji++)‏ 


X=X*10+i; 

coui<<x<<endl; 
1 
ُ 


أما كتابة البرنامج بطريقة يعطينا الخرج شكلا وليس رقم فهو: 
#include<iostream.h>‏ 
void main()‏ 
{ 
char c= '';‏ 
for(int i=1;ji<=5;i++)‏ 
{ 
for(int j=1;j<=i;jj++)‏ 
coui<<j<<C;‏ 
cout<<endl;‏ 


} 


ملاحظة : يمكن أن نكتب في السطر الواحد أكثر من أمر برمجي ولكنا فضانا أن لا نفعل ذلك من أجل 


الترتيب و فهم البرنامج مع أننا قمنا بذلك في بعض الأمثلة 


فیجوز مثلاً کتابة ;<< |أ٥;×<<‏ أ٥‏ على سطر واحد وهكذا . 


مثال: 
اكتب برنامج يقوم بحساب !م العاملي لأي رقم 
الحل : 


۷ 
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باستخدام الحلقة عاأإس 
#include<iostream.h>‏ 
void main()‏ 


int x,y,faci=1; 
cout<<" this program is for factorial calculation"; 


COUİl<<\N === 
cout<<"\n enter x"<<endl ; 

CİIN>>X; 

y=1; 
COUİi<<X<<"! = 
while(y<=X) 


{ 


fact=facty; 
y++; 


couit<<fact; 
ر‎ 
على الشكل التالي‎ ٤٥١ ويمكن كتابة البرنامج باستخدام الحلقة‎ 
#include<iostream.h> 
void main() 


int i,n,faci=1; 

cout<<" this program is for factorial calculation"; 
cout<<"\n copy right 2006"; 

cout<<"\n designed by hindawi"; 

COUİl<<\N === : 
cout<<"\n enter x"<<endl ; 

cin>>n; 

coUui<<N<<"! = ": 
for(i=1;ji<=n;i++) 


fact=factîi; 


cout<<fact; 


۲۸ 
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Fibonacci Series يشlنgبيف سلسلة‎ 


هي عبارة عن سلسلة أعداد يون أي رقم فيها يساوي مجموع الرقمين السابقين له و يكون الرقم الأول منها و 
اني سارى الراك 
أي كما في هذه السلسلة 
De n‏ 12351 1 
u‏ 
اكتب برنامج يقوم بحساب العناصر العشرة الأولى من سلسلة فيبوناشي 


۲۹ 
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مثال آخر: 
أوجد حدود فيبوناشي من أجل ۸ 
الحل: 
#include<iostream.h>‏ 
void main()‏ 


int a,b,c,i,n; 

char s=''; 

a=b=1; 

cin>>n; 
coui<<a<<Ss<<b<<sS; 
for(i=3;ji<=n;i++) 


c=a+b; 
Ccoui<<C<<S; 
a=b; 

b=c; 


3} 


تدریبات 

اکب برا کاو اع اکن الا 
12345 
| 2345 
34512 
45123 
51234 


#include<iostream.h> 
void main() 


{ 
int a,b,c,d,e; 
char s=''; 


coui<<a<<S<<b<<s<<C<<S<<d<<s<<e<<endl; 


۰ 
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wO OOO To 
TET 
e 


ست 


مثال: 
لكتب نرنامج يقو بطبا عا الشكل تااس على الشاشة 
A.1 A.2 A.3 A.4 A.5‏ 
B.1 B.2 B.3 B.4 B.5‏ 
CO.1 C.2 C.3 C.4 C:5‏ 
D.1 D.2 D.3 D.4 D.5‏ 
ËE.1 E.2 E. 3-EZ Fb‏ 


#include<iostream.h> 
void main() 


char A,B,C,D,E,y,s,n; 
CEE 
E 
for(y='A';J<='E';J++) 
{ 
cout<<endl; 
for(int i=1;i<=5;i++) 
coui<<yJ<<s<<i<<n; 


} 


مثال: 
اكتب برنامج يقوم بحساب ل١‏ لهذه المتوالية 
<<<<<<<<<< <2<4<8<16<32< 1 
الحل 
#include<iostream.h>‏ 
void main()‏ 


float a,b,n; 
char s=''; 
a=b=1; 
cin>>n; 
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couit<<a<<s<<b<<s; 
for(int i=3;i<=n;i++) 


{ 

b=2*a; 
couit<<b<<s; 
a=b; 

} 
} 


المصفوفات كلعجا!؟A‏ 


ك تتشابه في النوع : يعني أن تكون البيانات التي تخزنها ا لمصفوفة مثلاً كلها أعداد صحيحة. 


التصريح عن المصفوفه: 

هناك ثلاثة أشياء يجب أن تأخذ بعين الاعتبار عند التصريح عن المصفوفة 
© اسم المصفوفة : وهو اسم نختاره مثلما نختار اسم أي متغير. 

# عدد العناصر التى بداخلها. 

© نوع البيانات المستخدمة فيها. 


ويمكن أن تکتب كما في هذه الأمثلة: 


Int mark [5] ={1,3,2,4,6}; 
Int mark [ ] = {5,2,1}; 


êi 
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حیث: 
int‏ 
mark‏ 


[5] 


نوع البيانات التي بداخل المصفوفة 
اسم المصفوفة 
عدد العناصر داخل المصفوفة 


Int mark [5]; 


علما أنه في المصفوفات يبدأ ترقيم العناصر ( خانات المصفوفة ) وليس قيمتها بالرقم صفر 
أي وبشكل أوضح: 


العنصر ° 


» 


انا 


» 


٣” العنضر‎ 


" 


» 


آا کاس 


ومن هذا الشكل نستنتج بأن المصفوفة يبدأ ترقيمها من الصفر 


كيفية إدخال عناصر مصفوفة 
فإذا أردنا مثلاً أن نضع القيمة ۷١‏ في العنصر الثالث من المصفوفة يتم ذلك كما يلي 
Mark[2] = 75‏ 


البداية في المصفوفة تبدأ من الصفر ( أي المؤشر ) كما ذكرنا سابقا. 
كما في الشكل التالي 


4 3 2 1 0 رقم العنصر 


852 258 1 11 454 قيمة العنصر 


فهذه المصفوفة تتألف من خمسة عناصر . 

لنتمكن من إدخال قيمة عنصر-حرق أو رقم - في مصفوفة يجب علينا تحديد رقم العنصر حتى نتمكن من 
ذلك كما في المتال التالي: 

أدخل القيمة ۲ في المكان الثاني للمصفوفة [4] )2" 


i 
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الحل: 

cin>>mark[1]; 

طبعا كتبنا [1] لأن العنصر الثاني من المصفوفة يشار له بالرقم ١‏ 

ولأن العنصر الأول منها يأخذ المكان (0) كما تم ذكره سابقا 

كيفية إدخال عناصر مصفوفة بشكل متتالي: 

لإدخال عناصر مصفوفة اسمها )2۲م تتألف من خمس عناصر نتبع حلقة ٤0۲‏ كما يلي: 


for(int i=0 ; i<5 ; i++) 


cout<<" please enter array elements" ; 
cin>> mark [i] ; 


تنقسم المصفوفة إلى نوعين : 


-١‏ مصفوفة ذات البعد الواحد 
۲- مصفوفة ذات بعدين 


وتسمى المصفوفة [2,5,4,6 )۸ مصفوفة ذات البعد الواحد لأنها تتكون من صف واحد و إن كانت 


تتکون من عامود واحد فتسمی نفس الاسم . ص 
آما المصفوفة ذات البعدين فهي التي تتالف من آكثر من صف أو أكثر من عامود. 


ملاحظة : 
قد نحتاج في المصفوفات أو غيرها للتعامل مع قيمة ثابتة ( متلا ٠١‏ ) لمتحول ما( جم ) لا تتغير أبدا 
أي متحول ثابت القيمة فإننا نعرف هذا المتحول على الشكل التالي 

#define max 10‏ 
ففي هذه التعليمة فإن المتحول ×ه ص" آخذ القيمة )٠١(‏ طوال فترة تنفيذ البرنامج 
ولا يمكن أن يدخل ×ه" في أي من العمليات الحسابية أو الإسناد. 


مثال :اكتب برنامج يقوم بإدخال مرتبات عشرة موظفين ثم يقوم بحساب وطباعة متوسط هذه الرواتب 
#include<iostream.h>‏ 
تعريف المتحول التابت 10 #define max‏ 
void main()‏ 
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float salary[max]; 
float average ,sum; 
int count; 
sum=0.0; 
for(count=0;count<smax;count++) كيفية استخدام المتحول الثابت ضمن هذه الحلقة‎ 
{ 
cout<<"please enter salary for employee\n"; 
cin>>salary[count]; 
sum=sum+salary[count]; 
1 
average = SUM / max;  ةيبlسnحفلا استخدام المتحول الثابت ضمن العمليات‎ 
cout<<"\n salary average is = "<<average:;: 


1 


* يمكن إدخال جميع عناصر المصفوفة الاسمية 2۲ع دفعة واحدة كالتالي: 
cin >> mark [] ;‏ 
ونكتب الاسم المراد ادخاله بالكامل ثم نضغط إنتر 


بينما ليس بالإمكان فعل ذلك مع المصفوفة الرقمية اهمها "| إلارقم رقم . 
مال 
اكتب برنامج يقوم بإدخال أسماء الموظفين و عناوينهم 
#include <iostream.h>‏ 
void main()‏ 


char name[20]; 
char address[20]; 
for(int i=0;i<13;i++) 
{ 
cin>>name; 
cin>>address; 
cout<<name; 
cout<<address; 


} 
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كما نلاحظ أننا في هذا المثال أدخلنا اسم الموظف كاملا و عنوانه أيضا لأن اسم الموظف هو عبارة عن 
مصفوفة حرفية وكذلك العنوان 


#include<iostream.h> 
void main() 


{ 

float mark[5]; 

int sum=0; 

for(int i=0;i<5;i++) 


cin>>mark[i]; 
sum=sum+mark[i]; 


coui<<"sUM = "<<sUum; 


} 


شرح البرنامج 
ومن تم قمنا بجمع قيم عناصر هذه المصفوفة 


ملاحظة 
لقد كتبنا في المال السابق ٠‏ (++أٍٍ01>5-=| أ١i)٣ه؟‏ العبارة 5>¡ ولم نكتب 5->¡ لأن عناصر 
المصفوفة تبدأ من الصفر 


مثال آخر 
اكتب برنامج يقوم بإدخال سلسلة مؤلفة من عشرة رموز ثم يقوم بطباعتها وفق ترتيب الإدخال ثم بعكسه 


#include<iostream.h> 
void main() 
char s[10]; حددنا عناصر المصفوفة بأنها عشرة عناصر‎ 
for (int i=0;i<10;i++) حلقة لإدخال العناصر‎ 
cin>>s[i]; 


۳٢ 
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حلقة الإخراج التصاعدية for(i=0;i<10;i++)‏ 
cout<<s]i];‏ 

حلقة الإخراج التنازلية for(i=9;i>=0;i--)‏ 
cout<<s]i];‏ 

} 


ملاحظة هامة 

* فى هذا المتال أدخانا عناصر المصفوفة حرف حرف 

* لقد كتبنا حلقة الإخراج التنازلية بهذا الشكل 

for(i=9;ji>=0;i--) 

للأسباب التالية عندما 9أ¡ تنعي بأننا نريد العنصر العاشر 
عندما 0أ نعني بأننا نريد العنصر الأول 


تمارين حول المصفوفة أحادية البعد 
* اكتب برنامج يمن المستخدم من إدخال عشرة رموز ثم يقوم البرنامج بطباعة عدد مرات تكرار الحرفين 
۾ ^ في هذه السلسلة 


#include<iostream.h> 
#define n 10 
void main() 
{ 
int counit=O0; 
char s[n]; 
for(int i=0;ji<n;i++) 
{ 
cin>> sji]; 
if(s[i]=='A'||s[i]=='a') 
count ++; 


1 


cout<<count; 


1 


شرح البرنامج 
بعد أمر الادخال كتبنا الكود التالي 
if(s[i]j=="A'|Is[i]=='a')‏ 


من الات 
إن كان العنصر|المدخل يماوي القيمة ۸ أو 0۲ يساوي إلقيمة ج نفذ الييطر التالي 


۳۷ 
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والذي هو ++أ٣‏ امع أي زيد العداد بمقدار واحد 
فكلما تنفذ هذا الشرط زادت قيمة العداد حتى تمام إدخال عناصر المصفوفة فإن البرنامج يطبع قيمة العداد. 
مثال 

اكتب برنامج يُمَّكن المستخدم بإدخال مصفوفة أحادية البعد مؤلفة من عشرة أرقام 

ومن ثم يقوم البرنامج بطباعة الأرقام التي هي أكبر من خمسة 

مع طباعة أماكن تواجدها ضمن المصفوفة 


الحل: 


#include<iostream.h> 
#define n 10 
void main() 


int i,s[n]; 
for(i=0;i<n;ji++) 
{ 
cin>>s[i]; 
if(s[i]>5) 
{ 
cout<<"this number is begger of 5"<<endl; 
coui<<i<<" "<<s[i]j<x<endl; 
} 
3} 


شرح البرنامج 
إن القيمة .| تمثل مكازہتواجد الينصر داخل المصفوفة 
أما القيمة SII]‏ فانها تشكل قيمة هذا العنصر 


المصفوفات ثنائية البعد 
هي المصفوفات التي تتألف من أكثر من عامود أو أكثر من سطر 
مثال عليها: 


| 
سام [ 


ففى هذا المثال تتألف هذه المصفوفة من عامودين و تلاثة أسطر 
ولإدخال هذه المصفوفة يجب علينا بداية أن نعرف البرنامج بسطر ثم بعامود العنصر المراد إدخاله 
وتكون بالطريقة التالية: 
cin>> ali] J:‏ 
حيث : ج اسم المصفوفة 


۳۸ 


PDF created with pdfFactory Pro trial version www.pdffactory.com 


¡ رقم السطر 


ِ رقم العامود‎ j 
ويكون ترقيم الأسطر و الأعمدة حسب الشكل:‎ 
() 1 
لا لار‎ 
# 
ظر0‎ 6 5 
طر2‎ 3 7 


حيث يعبر الكود 1[]0[=1]ه أن القيمة ( ١‏ ) موجودة في السطر 1 و العامود 0 كما في الشكل 
السابق 

وكما أننا قد استخدمنا حلقة 0١‏ في المصفوفة أحادية البعد فإننا سنستخدم هنا حلقتي 0١‏ لإدخال المصفوفة 
ثنائية البعد كالتالي: 


for(i=0 ; i<3 ; i++) 


for(j=0 ; j<2; j++) 
cin>>alilÜ]: 


مثال : 

اكتب برنامج يقوم بإدخال عناصر مصفوفة تنائية البعد 

تتألف من سطرين وتلاثة أعمدة 

بحت بترم ارتام ادان عتا اممف فة ذات الت ال باق ٠‏ 
ثم يقوم البرنامج بطباعة شكل المصفوفة الجديد. 


الحل: 


#include <iostream.h> 
void main() 
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int s[2][3],i,j; 

for(i=0;i<2;i++) 

for(j=0;j<3;j++) 
{ 


cin>>s[i][l; 
if(s[i]j]%2!=0) 
sliJj]=10; 


for(i=0;i<2;l++) 
{ 
for(j=0;j<3;j++) 


cou <S E 
cout<<endl; 


1) 


السجلات ( التركيبات ) ع٥١ suc]‏ 


النوع : أي أن يكون بعضها من نوع ا"¡ وبعضها 2۲٣م‏ وبعضها أهه|f‏ وبعضها .......الخ. 


فمنذلاً ٠‏ 
لكتابة بر تامج اتسجيل بيانات مر فين في الشرگة نکتاج إلۍ تخزين-": 


char ١a۳6]40[ اسم الموظف وهو من نوع مصفوفة حرفية‎ -١ 


- عنوانه وهو من نوع مصفوفة حرفية char address[40]‏ 
۳- عمره متحول من نوع عدد صحیح int age‏ 
-٤‏ راتبه متحول من نوع عدد حقيقي float salary‏ 


وكما نلاحظ فإن جميع هذه البيانات يجب التعامل معها كوحدة واحدة لأنها لموظف واحد 
ولذلك فإننا بحاجة إلى سجل خاص لهذا الموظف 


كيفية الإعلام عن السجل : 
للتصريح عن سجل نستخدم الكلمة المحجوزة اع ل۲]ء وهي اختصار لكلمة ۲٥‏ ںام ں٣]ء‏ ومعناها تركيب 
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ونضع جميع مكونات هذا التركيب ضمن قوسين ونختم التصريح بفاصلة منقوطة بعد القوس الثاني 
ثم يتم التصريح عن متحول خاص لهذا التركيب ( السجل ) ضمن القائمة الرئيسية للبرنامج . 
وبك اللضر دة خن الشخل باكرط ر اة 


کما نلاحظ 


فإننا كتبنا السجل وكتبنا بداخله جميع المتحولات الموجودة بداخله 
ومن ثم بدأنا بكتابة البرنامج بالعبارة المعتادة ( ) ٣أكة"‏ ل۷0 ومن ثم صرحنا 
عن متغير خاص بهذا السجل - طبعا نختار اسم المتحول كيفيا - ومن ثم نتابع كتابة البرنامج 


كيف نكتب المتحولات داخل السجل ( كيفية كتابة هذا السجل ) 


#include <iostream.h> 
struct employee 


مصفوفة لكتابة اسم الموظف char name[40];‏ 
مصفوفة لكتابة عنوان4 char address[40];‏ 

متحول لكتابة عمره int age;‏ 

متحول لكتابة راتبه float salary;‏ 

}; 


Void main ( ) 


struct employee emp; 


كيفية إدخال وإخراج المعلومات داخل هذا السجل 
عندما نريد متلا إدخال عمر الموظف فاننا نكتب 
Cin >> emp . age ;‏ 


وعندما نريد إدخال اسم الموظف نكتب 
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Cin >> emp . name; 
و لا نكتب الأقواس عندما نريد إدخال الاسم كاملا كما تعلمنا في المصفوفات‎ 


أما عندما نريد إخراج أي قيمة فإننا نستبدل ١أع‏ ب ألاهع كما هو معروف 


ويمكننا أن نعلم عن التصريح بطريقة أخرى 


اكتب برنامج يقوم بإدخال معلومات عن 
-١‏ اسم الموظف 
۲- عنوانه 
-٣‏ عمره 
-٤‏ راتبه 
#include<iostream.h>‏ 
طبعا لا نضع هنا فاصلة منقوطة struct employee‏ 
char name[40];‏ 
char address[40];‏ 
int age;‏ 
float salary;‏ 
1 
void main()‏ 
{ 


struct employee emp; 
cout<<"enter name"<<endl; 


۲ 


PDF created with pdfFactory Pro trial version www.pdffactory.com 


cin>>emp.name:; 
cout<<"enter address"<<endl; 
cin>>emp.address; 
cout<<"enter age"<<endl; 
cin>>emp.age: 

cout<<"enter salary"<<endl; 
cin>>emp.salary; 


1 


ولكن إن كان لدينا أكثر من موظف مثلا ثلاثة عشر موظف فإننا بحاجة إلى مصفوفة سجلات 


كيفية التصريح عن مصفوفة سجلات 


نفس الطريقة السابقة ولكن نجعل المتحول عبارة عن مصفوفة ونضيف سطر برمجي 
وهو حلقة 0۲] كما كنا نكتبها في المصفوفات . 


مثال عملي: 
لتعدكتابة البرناطج_السابق-ولكن لثلاثة عش موظفا ندخل المعلومات-عنهح ومن ثم تخر جها 


#include<iostream.h> 
struct employee 


char name[40]; 
char address[40]; 
int age; 
float salary; 
1 
void main() 
{ 
struct employee emp[13]; 
for(int i=0;i<13;i++) 
{ 
cout<<"enter name"<<endl; 
cin>>emp|i].name; 
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cout<<"enter address"<<endl; 
cin>>emp|i].address; 
cout<<"enter age"<<endl; 
cin>>emp|i].age; 
cout<<"enter salary"<<endl; 
cin>>emp[i].salary; 


ا 
for(i=0;ji<13;i++)‏ 


cout<<emp|i].name<<emp|[i].address<<emp|[i].age<<emp|i].salary<<endl; 


سؤال: 
إن أردنا توسيع هذه المسألة مثلاً أن تكون مجموعة من الموظفين تابعة لقسم ما أو لشركة ما 
فماذا نفعل؟ 


نحن هنا بحاجة إلى تعريف سجل داخل سجل. 
تعریف سجل داخل سجل آخر 


sS 
ويتم إسناد هذا السجل إلى سجل آخر وهو القسم أو المؤسسة التي‎ a يدخل اسم الموظف وعنوانه و‎ 
يوجد بها هذا الموظف‎ 
فيكون هنا سجل المؤسسة هو السجل الرئيسي أما سجل الموظف فهو السجل الثانوي‎ 
وليس من الضروري - في كتابة الكود - كتابة أي سجل قبل الاخر‎ 


ال غ ذلك ٠‏ 
سجل الموظف ثانوي  Struct employee‏ 


{ 

Char name[20]; 
Char address[40]; 
Int age; 

Float salary; 
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1 

سجل القسم رئيسي Struct dept‏ 

نعرف متحول رقم القسم Int deptno;‏ 

نعرف متحول المشروع Int projct;‏ 

نعرف هنا متحول السجل التانوي داخل الرئيسي ‏ ;ضmp€ Struct employee‏ 
1 


أما عن كيفية الإدخال و الإخراج فإننا نكتب 

فإذا أردنا إدخال مثلا عمر الموظف فإننا نكتب اسم السجل الرئيسي تم المتحول للسجل الثانوي ثم مكان 
الإدخال أما في حال إضاقة معلومة ضمن السجل الرئيسي فيكفي كتابة اسم السجل الرئيسي ثم كتابة اسم 
مکان الادخال 


: مثال‎ 
Dept.emp.age; 
Dept.deptno 


ملاحظة: 
من أجل إدخال سلسلة حرفية - فقط - يمكن استخدام التعليمة ءامن بدل التعليمة <<”أم في حال 
استخدام المكتبة التابعة لهذه التعليمة وهي <0.۸٥أQآء>‏ ويكتب الكود كالتالي: 

gets (emp|i] .name); 


Function 
هو عبارة عن برنامج فرعي مهمته تنفيذ مهمة معينة حين يتم استدعاؤه‎ 


مما يتألف البرنامج الفرعي 
-١‏ التصريح عن البرنامج ( وسيأتي شرحه بعد قليل )وينتهي بفاصلة منقوطة 
ولكن إن كان التصريح خارج ( قبل ) التعليمة 
Void main ( )‏ 
فإن البرنامج الفرعي يكون مشاع (لكل البرامج المتاحة في البرنامج) 
آما إن کتب داخل جسم 
Void main ( )‏ 
فإن البرنامج الفرعي يكون حكراً على هذه التعليمة . [ 
۳- جسم البرنامج وهو يشابه طريقة كتابة البرنامج الرئيسي وطبعا بدون فاصلة منقوطة 
ويكتب جسم التابع بعد نهاية كتابة جسم البرنامج الرئيسي 
كيفية التصريح عن هذا التابع: 
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وهو بأن نكتب اسم خرج التابع ثم اسم التابع ومن ثم نكتب نوع البارامترات أي نوع الخرج 


ويمكن أن يكون خرج التابع 


فارع 


مثال: (بدون عملية إرجاع أي قيمة ) أي بدون حاجة إلى خرج 
اکتب برنامج يقوم بمعرفة العدد . المدخَل من قبل المستخدم- مو جب ام سالب 


void 

int 
void 
float 


#include<iostream.h> 
void positive (int); لا ننسى كتابة الفاصلة المنقوطة‎ 
void main() 


int x; 
do 
{ 


CiIN>>X; 
مsi†|۷٥‎ )×(; استدعاء البرنامج الفرعي كود طلب البرنامج‎ 


while(x !=0); 
ر‎ 
void positive (Î a) البرنامج الفرعي‎ 


{ 

if(a<0) 

cout<<a<<"'is a negative number"; 
else 

cout<<a<<"'is the positive number "'; 


} 
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شرح البرنامج: 

تم التصريح عن البرنامج بالكود التالي 

void positive (int); 

ومعناه بأن البرنامج غير مطالب بإرجاع ( خرج البرنامج الفرعي ) إلى البرنامج الأساسي 

من خلال التعليمة Qإأ۷0‏ 

ثم من خلال حلقة ءاأاس م طالبنا البرنامج بالعمل طالما أن المتحول × لا يساوي 

الصفز 

وتم استدعاء البرنامج الفرعي من خلال الكود التالي 

positive (xX); 

فبواسطة هذه التعليمة فإن البرنامج سيقفز مباشرة إلى البرنامج الفرعي و المتمثل بالتالي 
void positive (int a)‏ 


{ 

if(a<0) 

cout<<a<<"is a negative number"; 
else 

cout<<a<<"'is the positive number "'; 


} 


لقد عرفنا هنا المتحول ج بمتحول شكلي و تسند قيمة المتحول الفعلي × المدخلة عليه 
ومن ثم تفذنا عليه هذا البرنامج الفرعي ٠‏ 

وبعد الانتهاء من البرنامج الفرعي يعود البرنامج لمتابعة البرنامج الرئيسي و المتمثل هنا 
إعادة إدخال القيمة × 


ملاحظة هامة: 

يوجد طريقتين للتصريح عن التابع 

۷0أQ أن نقوم بالتصريح عن التابع ومن ثم نقوم بكتابة التابع بشكل كامل بعد نهاية‎ -١ 
بالكامل أي بعد نهاية القوس الثاني.‎ ها٠‎ 

- أن نقوم مباشرة بالتصريح عن التابع وكتابة جسم التابع مباشرة ولا نكتب التصريح 


مثال: مع الحاجة إلى إرجاع 
اكتب برنامج يكتشف أكبر عدد من ثلاثة أعداد مدخلة عليه. 
#include<iostream.h>‏ 
نحن هنا بحاج للتعامل مع ثلاث باراlمترlٽت int great (int,İin,İ);‏ 
void main()‏ 


1 
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int a,b,c,d; 

Cin>>a>>b>>c; 

كود طلب البرنامج الفرعي ;(٥,9۲۵)8,0=ل‏ 
cout<<d;‏ 


ر 
البرنامج الفرعي int great(int X,int J,İ z)‏ 


int max; 

max=x; 

if(y>max) max=y; 

if(z>max) max=z; 

تعيد هذه التعليمة البرنامج إلى آخر قيمة للمتحول المكتوب return max;‏ 
بعدها } 


ملاحظة هامة جداً 

* نلاحظ أن التابع في هذا البرنامج يقوم بإعادة قيمة واحدة إلى البرنامج المستدعي فللاستفادة 
من هذه القيمة المرجعة يجب استخدام متحول آخر تسند إليه قيمة خرج هذا التابع 
d=great(a,b,c);‏ 


* عندما يكون التابع يعيد قيمة فإن هذه القيمة سوف تعاد ضمن الأمر ١ا۲6‏ حيث أن وظيفة 
هذه التعليمة هي تمرير القيمة المكتوبة بعدها إلى البرنامج المستدعي 


متال : 
اكتب برنامج يقوم برفع عدد الى قوة بدون استخدام الأمر (W)×,۸٥م‏ الممكن ضمن 
المكتبة 
<maith.h>‏ 
مع العلم أن (ط)ءطه عبارة عن تابع يعطي القيمة المطلقة للقيمة (ط) 
الحل: 
#include<iostream.h>‏ 
#include<math.h >‏ 
float power(float,int);‏ 
void main()‏ 
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float x; int n; 
Cin>>X>>n; 
cout<<power (x,n); اطلب البرنامج الفرعي وطبع القيمة المعادة‎ 


ا 
البرنامج الفرعي float power (float a,İnt ٥(‏ 


float c; int i; 

C2; 

for(i=abs(b); i>1;i--) 
C =a; 

if(b<0) c=1/c; 
return C; 


} 


اكتب برنامج من أجل حساب و طباعة قيمة العلاقة التالية 
إ5 + إ4 + !3 + !2 + !1 + Sum = O!‏ 


الحل: 
#include<iostream.h>‏ 
int fact (int);‏ 
void main ()‏ 


int sum=0,i; 

for(i=0;i<=5;i++) 

طلب خر ج البرنامج الفرعي خمس مرات وجمع القيم المرجعة sum+=fact(i);‏ 
coui<<"sUMm = "<<sUum;‏ 

ا 
int fact (int n)‏ 
٠‏ 
int I,S;‏ 

S=1; 
for(i=n;ji>=1 ;i--) 
S*=i; 
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return S; 


1 


اكتب برنامج من أجل حساب وطباعة قيمة التعبير التالي 
SUM = 1 + X1 + X^2 + X^3 + X14 + x5‏ 
مع العلم أن )»٠"(‏ تعني أن الرقم اكس مرفوع إلى القوة " 
باستخدام الامر ;(أ,×)W‏ 0م 
#include<iostream.h>‏ 
#include<math.h>‏ 
void main()‏ 


int sum=0,x,i; 
CİIN>>X; 
for(i=5;i>=1 ;i--) 
SUM+=poWw(x,i); 
coui<<sum; 


1 


الملفات S؟ع٤F۴|IL‏ 


الملفات هي عبارة عن وسائط لتخزين البيانات بحيث يتم الكتابة عليها و تحفظ هذه البيانات 
بداخلها 

سنقوم بهذا الدرس بشرح كيفية التعامل مع الملفات من حيث القراءة و الكتابة على أن نستعين 
ببعض مكتبات لغة © 


شرح بعض تعليمات لغة © [ 
أو يجب ان نعلم أن المكتبة الداعمة لهذه الاوامر هي > <Stdio.h‏ 


الشرح 
لفتح ملف يجب علينا تحديد مسار هذا الملف و امتداده 
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ويجب علينا أيضا تحديد مكان في الذاكرة لحجزه لهذا الملف.بالتعليمة ۴|٤ *f‏ 
ويجب علينا الانتباه بأن الكلمة ۴|1۴ يجب أن تكتب بأحرف كبيرة حصراً 
وعند فتح هذا الملف يجب علينا إخبار البرنامج بأننا هل نريد القراءة من هذا الملف أم الكتابة 


ام الاثنتين ا / 
فلكتابة نستخدم f = fopen("c:\student.txt","w");‏ 
چا للقراءة N e‏ م اال 


وفي خا القراءة و الكتابة ذ 6 م ا" أو "w+"‏ 


: مثال‎ 
#include <stdio.h > 
void main ( ) 


{ 
BEET‏ 
f=fopen("c\\stdudent.txt","w");‏ 
fprintf(f," welcome to C++");‏ 
fclose(f);‏ 
1 
ولطباعة ++€ 0ا eمصomعاwe‏ في هذا الملف الذي تم فتحه أو إنشاءه نستخدم الكود التالي 
fprintf(f," welcome to C++");‏ 
وإن التعليمة 1٣م‏ تكافئ التعليمة ارمع في المكتبة "64,]كئ0|ا 
ومن أجل اغلاق هذا الملف استخدمنا هذا الكود 


fclose(f); 
وإن هذه التعليمة تقوم بإغلاق هذا الملف وتنهي التعامل معه وعدم كتابة هذه التعليمة يمكن أن‎ 
. يؤدي في بعض الاحيان إلى تلف أو ضياع البيانات‎ 


ملاحظة : 
"هند الظلب من لبر نام جام فك ملف فإن_الير نامج ار لم بجلاهندالطةفإن الير ذامج 
يتش هذا الملفا. 
* في حال عدم كثابة مسار ألملت المنشاً من قبل البرنامج فإن البرتامج سينشئ هذا الملف في 
المشبار الافر اضى لزنام ( السار الموجود به اللزذامي. 


مثال : 
اكتب برنامج يقوم بإنشاء ملف نصي من أجل تخزين علامات طالب ضمن هذا الملف 
#include<iostream.h>‏ 
#include<stdio.N>‏ 
#include<stdlib.N>‏ 
void main()‏ 
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حجز مكان للملف المنشİ FILE *out;‏ 

int score; 
if((out=fopen("test.txt","w"))==NULL) 
{ 


cout<<"can not open file\n"; 
exit(-1); هذه التعليمة تقوم بإنهاء البرنامج‎ 
} 
cout<<"enter a test score (O terminate input)"; 
cin>>score; 

while(score !=0) 


fprintf(out, "Yod\n",score); 

cout <<"enter anather score"; 
cin>>score; 

} 


fclose(out); 


1 


شرح اردع 
بداية تم استخدام مكتبة جديد ة هي مأاك]ء لاستخدام بعض الاوامر منها 
سنكتب الأكواد بالترتيب مع الشرح 
FILE *out;‏ 
تحديد مكان في الذاكرة للتعامل مع الملف وأطلقنا عليه اسم ألا 
وکما ذکرنا سابقا كلمة ۴|1٤‏ تكتب بأحرف كبيرة حصراً 
int score;‏ 

if((out=fopen("test.txt","w"))==NULL) ٠ 
وتكتب باحرف كبيرة حصراً ) فشل › إحباط وهي كلمة محجوزة‎ ( NULL معنآ‌‎ 
: قيكون الكود‎ 
إذا لم يتم فتح هذا الملف لسبب من الأسباب ( مثل : القرص محمي ضد الكتابة ) نفذ السطر‎ 
التالي في البرنامج وإلا فتخطاه‎ 
exit(-1); 
قم بإنهاء البرنامج وهي من المكتبة طأافاك‎ 
إن حلقة | متضمنة الأمرين معا:‎ 

cin>>score; 

أمر إدخال قيمة المتحول وهو إدخال علامة الطالب 
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while(score !=0)‏ 
طالما أن العلامة لا تساوي الصفر نفذ الأوامر التالية 
وقد كتبت من أجل تضمين البرنامج أمر ليتسنى لنا الخروج من البرنامج 
fprintf(out,"%od\n",score);‏ 
تفيد هذه التعليمة أن ما يكتب في الملف هو من نوع |١‏ 
fclose(out); :‏ 
وهو امر لإغلاق الملف. 


كيفية التعامل بين الملفات و السجلات 


وتكون بنفس طريقة طباعة الملف مع مراعاة كيفية كتابة الأمر ۴١۲م‏ و يكون كتالي 

; ( اسم السجل . اسم متحول السجل , "5 % " , اسم الملف المحجوز بالذاکرة )٤٤۸٣م‏ 
فمثلا : ليكن لدينا السجل التالي : 

struct employee 

2 empno; 

char name([20]; 

float salary; 


1 
فاذا ردنا طباعة مصفوفة الاسم [۳"6]20 ه4" داخل الملف فإننا نكتب الكود 
fprintf (myfile %s ", emp|i].name);‏ 
أما إن أردنا طباعة هذا السجل بالكامل فإن الكود يكون ( على سطر واحد يكتب هذا الكود) 
fprintf‏ 
(myfile, "'%d\t%os\tYof\n",emp[i].empno,emp[i].name,emp[{i].salary);‏ 


or 
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كما نلاحظ بأننا عند التعامل مع الملفات نحن بحاجة للتعامل مع المكتبة < 0.۸ألأ؟S>‏ 
مثال : 

اكتب برنامج يقوم بقراءة بيانات الموظفين ومن ثم يقوم بتخزينها في الملف )»|.أںم علما 
أن البيانات تتضمن رقم الموظف واسمه وكذلك راتبه 

*سنشرح الاأكواد داخل البرنامج 

٠: *ملاحظة‎ 

بعض الاأكواد طويلة ولم تتسع معنا بسطر واحد ولم نرغب بتصغير الخط ولذلك يرجى 
الانتباه مع العلم بأننا نبهنا إلى ذلك في مكان كتابة الكود 


#include<iostream.h> 
#include<stdio.hN> 
#include<stdlib.N> 
void main() 


حجز مكان في الذاكرة بهذا الاسم FILE *myfile;‏ 
كتابة JlسجJ struct employee‏ 


تعريف رقم الموظف داخل السجل int empno;‏ 

تعريف مصفوفة اسم الموظف داخل السجل char ۸a۳6]20[;‏ 
تعريف راتب الموظف داخل السجل float salary;‏ 

1 

employee emp]100[; تعريف مصفوفة متحول للسجل‎ 
int i,n; 


if((myfile=fopen("out.txt","w"))==NULL) 
{ 


cout<<"can not open file"; 


exit(-1); 

cout<<"enter the number of employee<=100"; 
cin>>n; 

تحديد عدد السجلات المراد إدخlلا for(i=0;i<n;ji++)‏ 

{ 


o 


PDF created with pdfFactory Pro trial version www.pdffactory.com 


cout<<"enter the number of employee"<<i<<" : "; 

cin>>emp|i].empno; 

cout<<"enter the name of employee"<<i<<" : "; 

cin>>emp|i].name; 

cout<<"enter the salary of employee"<<i<<" :"; 

cin>>empl|i].salary; 

fprintf 

(myfile,"Yod\tYos\t%f\n",emp|[i].empno,emp|[i].name,emp|[i].salary); 
یکتب هذا الکود فی سطر واحد فیرجی الانتباه‎ 

”وسار _طباعة البدجلات لخ -الك لبو اسطة أمر الطباعة 


1 


أمر إغلاق الملف ;(eااyfرہ)loseاfc‏ 


1 


القراءة وانکتاوار لی ملف پر تامج واحد 
اكتب برنامج يقوم بقراءة بيانات الموظفين وذلك من الملف المنشاً سابقاً ».اام ومن ثم 
يقوم البرنامج بترتيبها حسب الاسم ثم يقوم بإعادة تخزينها بنفس الملف 


#include<iostream.h> 

#include<stdio.N> 

#include<stdlib.N> 

مكتبة جديدة لاستخدام أمر المقارنة و İأمر‏ lاJاwتفluر  #include<string.h>‏ 
void main()‏ 


{ 
FILE *myfile; 
struct employee 


int empno; 
char name[20]; 
float salary; 


oo 
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1 

employee emp[100],temp: 

MIO EO; 
if((myfile=fopen("out.txt","r+"))==NULL) شرح سابقا‎ 
{ 


cout<<"can not open file"; 
exit(-1); 


1 

يجب الانتباه بأن الكود التالي يكتب على سطر واحد 
fscanf(myfile, "YodYos%f",&emp{i].empno, &emp|[i].name,&emp|[i].s‏ 
alary);‏ 


أمر فتح الملف ويجب الانتباه لعلامة الربط & بين المتحولات 
while(!feof (myfile))‏ 
؟0هf‏ تعني |e‏ گە finc۴ ¡n‏ ومعناها هل انتهى الملف ويكون الشرح 
طالما لم يتم الوصول لنهاية الملف تابع 
{ 
زيادة واحد واحد للوصول للسطر التالي لنقل المعلومات منه I++;‏ 
عداد لمعرفة عدد الاسطر ;++ 


يكتب الكود على سطر واحد 
fscanf(myfile,"YdYos%f",&emp[i].empno,&emp|[i].name,&emp|i].s‏ 
alary);‏ 
فتح سطر كما تم ذكره ولكن هنا يكون هذا السطر هو السطر التالي كل مرة ضمن الحلقة 
1 
for(i=0;i<n;i++)‏ 
for(j=i+1;j<n;j++)‏ 
if(strcmp (empl[i].name,empjj].name)>0)‏ 
مصrcاء‏ تعليمة مقارنة وتكون النتيجة أكبر من الصفر في حال كانت القيمة الاولى أكبر 
من القيمة الثانية 
وتكون مساوية للصفر إذا تساوت القيمتين 
وأصغر من الضفر إذا كانت الثانية أكبر من الأولى 
{ 
كود ذكي لتبديل مكان السجلات temp=emp|i];‏ 
emp[ij=empl];‏ 
empljj=temp;‏ 
} 


حلقة من أجل الكتابة الى الملف ٠‏ (++أإم>اi=0)اfo‏ 
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fprintf(myfile, "Yod\tVos\tYof\t",emp[i].empno,empf[i].name,emp|[i].sal 
ary); 
fclose(myfile); 
} 
شرح الكود الذي اسمیناه دکي‎ 
داخل السجل م6۳ ليتسنى لنا‎ ٠" نضع السجل [ا] م‎ 
م6۳ ومن تم‎ ]i[ نقل السجل  [ز] م٣٥ الى داخل السجل‎ 
ع۳p الى داخل السجل [ز]‎ ]٥ ٣م‎  لجسلا ننقل‎ 
emp وبھذا نکون قد آبدلنا مکانا السجل إ[ا] م٣٠ بالسجل إز]‎ 


أخوكم في الله 


محمد هنداوي ۸/۳۰ / ۲۰۰١‏ 


mh2n@scs-net.org 


oV 


PDF created with pdfFactory Pro trial version www.pdffactory.com 


